草庐IT

c++ - 标准 :forward inside a template class

全部标签

无法读取 utmpx 文件

packagemainimport("os""fmt")funcmain(){fd,err:=os.Open("/var/run/utmpx")fmt.Println(fd,err)vardata[]bytelen,err:=fd.Read(data)fmt.Println(len,err)}&{0xc42000a240}nil0nil没有错误,也没有数据。这个路径/var/run/utmpx是从系统头文件中读取的。如何得到这个路径是anotherquestion系统:macOSelcapiton,go版本go1.8darwin/amd64**我的最终目标是将此文件读入gostruct

go - 是否有将包拆分为模块化组件的标准做法?

我正在开发一个具有多层功能的库。我希望开发人员能够只导入他们需要的部分,即mylib-core、mylib-feature1、mylib-feature2等。每个人都生活在自己的git仓库中。我还想提供一个简单的mylib包,它公开了一组默认功能,这对库的新开发人员很有用。参见d3.js版本4+用于与我正在尝试完成的非常相似的事情。我遇到的问题是显然您不能在包之间共享包名。这是一个问题,因为最好导入所有需要的存储库,然后简单地在mylib名称下提供所有可用内容。我没有看到一个明显的方法来重新导出功能,以构建默认的mylib包。是否有好的解决方案或更惯用的方法来实现我的目标?

c - 与 c 相比,Go 的二进制大小

这个问题在这里已经有了答案:ReasonforhugesizeofcompiledexecutableofGo(3个答案)关闭6年前。昨天我只是想比较简单的golangHelloWorld应用程序和c,gobinary是2-3MB(只是fmt.Println)然而,等效的C代码只有大约20kb(printf)。然后我检查了两个二进制文件正在执行的系统调用,使用strace;两者之间没有太大区别,所以你知道为什么golang二进制文件与等效的c语言相比如此庞大吗?

go - 替换Golang标准包并在内部调用原来的

假设有一个特殊的硬件可以使某些标准库功能更快。硬件可能存在也可能不存在。我可以写一个包来使用这个硬件功能签名与标准签名一样,但它会强制所有应用程序和其他包根据特定目标上硬件的可用性来决定导入哪个包。在构建时并在所有应用程序和包中修改代码。理想情况下,我更愿意在运行时决定使用哪个包,而不需要应用程序更改它们的导入。该包将检查硬件的可用性,然后使用它或执行标准功能。有什么办法可以实现吗?还有其他方法可以“拦截”对标准包函数的调用吗? 最佳答案 听起来你在谈论一个将被其他应用程序使用的库。您不能(谢天谢地!)以这种方式修改标准库——否则仅

c - 从 Golang 中的 c 函数返回字符串

我正在尝试在GO中调用C函数。这适用于某些扩展(对于整数)。但是,存在问题下面给出了一个最小的例子packagemain/*#include#include#includevoidmy_reverse(char*src,intlen,char*dst){dst=malloc(sizeof(char)*(len+1));printf("[c-part]src=%s\n",src);for(inti=0;i这是两个c函数,它们在c中分配一个新的缓冲区。但是,我得到了输出[c-part]src=HelloWorld[c-part]dst=dlroWolleH[gopart]dst=willr

c - 找不到gmp库

我试着安装依赖gmp的pbc库。Dockerfile:FROMgolang:1.9.6-alpine3.7RUNmkdir-p/go/src/appWORKDIR/go/src/appCOPY./go/src/appRUNapkadd--updategitgccbuild-baseflexbisongmpRUNwgethttps://crypto.stanford.edu/pbc/files/pbc-0.5.14.tar.gz&&\tar-xvfpbc-0.5.14.tar.gz&&\cdpbc-0.5.14&&\./configure--prefix=$HOME/.local&&\m

c - 添加文件到/usr/local/include

我最近在一台linux机器上安装了openjtalk,我希望能够用Go包装它。openjtalk的源文件有几个不同来源的子文件夹,我假设是编译器找到的,因为有make文件。我应该将每个子文件夹复制到/usr/local/include中吗?这是修复包含依赖项的“正确”方法吗?根据我的测试,如果我复制包含的文件,Go似乎可以找到它们,但我不确定这是否是正确的linux做事方式。 最佳答案 更改外部库的位置通常不是一个好主意。有些库会自动将自己放入编译器的包含路径中,但对于那些不这样做的库,将它们的路径添加到编译器的包含路径中总是一个更

c - 如何将 char * 更改为等效的 Go

我有一些看起来像这样的C代码-*((Oid*)((char*)(tup)其中Oid是一个uint32类型,tup是一个结构。我想把它转换成golang。我已经解码了结构,但无法弄清楚如何将上面的行转换为golang。 最佳答案 Go等价于转换C指针是将指针转换为unsafe.Pointer,然后可以将其转换为您希望的任何类型的指针。如果tup是指向C中结构的指针,您可以将它转换为*uint32,如下所示:u:=(*uint32)(unsafe.Pointer(C.tup)) 关于c-如何

c - 不在 cgo 中显示 printf 结果

当我运行这段代码时,我希望打印出类似A:4,B:89的结果。但实际上,不显示任何内容。为什么这个程序不将结果显示到标准输出?main.go:packagemain/*#include"c.h"*/import"C"import("unsafe")typeSstruct{AintBint}funcmain(){s:=&S{A:4,B:89}pass_to_c:=(*C.S)(unsafe.Pointer(s))C.gostruct(pass_to_c)}c.h#include#includetypedefstruct{longintA;longintB;}S;externvoidgost

api - 如何找出 Go 标准库函数的可能错误值?

当调用返回错误的Go函数时,我想知道如何处理非nil错误值。我可以中止、记录它或将其传递给调用者。或其组合。但如果我能找出问题所在并以更细粒度的方式使用react,那就更好了。因此,我如何才能找出可能的错误值及其含义?例如,我想使用http.NewRequest函数。查一查inthedocs.在那里,它只说有可能的错误条件,但没有说是哪些。我怎样才能找到这些? 最佳答案 首先,如果您还没有读过,我建议您阅读thisblogarticleabouterrorhandlinginGo,它可能会为您澄清一些事情。至于找出Gostdlib函